#pragma once

#include <stdio.h>
#include <assert.h>
#include <stdlib.h>
#include <stdbool.h>

typedef int QDataType;

typedef struct QListNode
{
	QDataType _data;
	struct QListNode* _next;
}QNode;

typedef struct Queue
{
	QNode* _front;
	QNode* _rear;
	int size;
}Queue;


void QueueInit(Queue* q);

void QueueDestory(Queue* q);

void QueuePush(Queue* q, QDataType data);

void QueuePop(Queue* q);

int QueueSize(Queue* q);

QDataType QueueFront(Queue* q);

QDataType QueueRear(Queue* q);

bool QueueEmpty(Queue* q);